/*
语法百题 解题报告：
 http://git.oschina.net/et0662/sznoi-grammar/ 
*/
#include<stdio.h>

int a[11];
int b[11];
int max, zz;

void search(int n)
{
	int i;
	if(n==(zz+1))
	{
		for(i=1;i<=zz;i++)
		{
			printf("%d ",a[i]);
		}
		printf("\n");
	}
	else
	{
		for(i=1;i<=max;i++)
		{
			if((i>a[n-1])&&(b[i]==0))
			{
				b[i]=1;
				a[n]=i;
				search(n+1);
				b[i]=0;
			}
		}
	}
}

int main(void)
{
	scanf("%d%d",&max,&zz);
	search(1);
	return 0;
}
